草庐IT

php - 在sql中使用lat和long查找距离

全部标签

ruby - 为什么要避免在 Ruby 中使用 then 关键字?

在一些Ruby风格指南中提到你应该“永远不要使用”。就个人而言,我认为“then”关键字可以使代码更密集,这往往更难阅读。此建议还有其他理由吗? 最佳答案 我几乎从不使用then关键字。但是,有一种情况我认为它大大提高了可读性。考虑以下多条件if语句。示例Aifcustomer.jobs.present?&&customer.jobs.last.date.present?&&(Date.today-customer.jobs.last.date)行太长。难以阅读。示例Bifcustomer.jobs.present?&&custom

ruby - 如何编写正则表达式以仅查找四位数的数字?

我正在尝试在Ruby中编写一个正则表达式来搜索字符串中只有四位数字的数字。我正在使用/\d{4}/但这是给我四位数或更多位数的数字。例如:“12345-456-6575一些文本9897”在这种情况下,我只需要9897和6575,但我还得到了长度为五个字符的1234。 最佳答案 "12345-456-6575sometext9897".scan(/\b\d{4}\b/)=>["6575","9897"] 关于ruby-如何编写正则表达式以仅查找四位数的数字?,我们在StackOverflo

ruby-on-rails - Mongoid:通过id数组查找

我已经通过MapReduce获取了一些ID。我已经按照一些标准对这些ID进行了排序,现在我需要按照这个特定的顺序获取这些对象:MyModel.find(ids)对吧?但它返回的对象不在存储id的顺序中。看起来这和MyModel.where(:_id.in=>ids)它不会以与存储ID相同的顺序返回获取的对象。现在我可以做到了ids.map{|id|MyModel.find(id)}这将完成这项工作,但它会多次敲击数据库。 最佳答案 正在研究类似的问题并找到了更简洁的解决方案:objs=MyModel.find(ids).sort_b

ruby - 使用已经存在的键在散列对象中附加一个值(在 Ruby 中)?

如何使用已有值的键在Hash对象中追加一个值。例如如果我有>>my_hash=Hash.new>>my_hash[:my_key]="Value1"#thenappendavalue,letssay"Value2"tomyhash,usingthatsamekey"my_key"#sothatitcanbe>>my_hash[:my_key]=>["Value1","Value2"]我知道编写自己的方法很容易,但我只是想知道是否有内置方法。 最佳答案 我不知道我是否没有理解您的观点,但您是否考虑过以下问题:1.9.3(main):0

ruby-on-rails - 为什么在检查依赖项时使用 GemSpec + GemFile?

每当开发gems时,我看不出有任何理由不直接检查Gemfile的依赖关系。的确,为什么要使用.gemspec文件来列出它们?有真正的好处吗? 最佳答案 那是因为Gemfile不是来自Rubygems的文件,而是来自Bundler的文件。因此,Rubygem开发人员必须扩展他们使用的文件才能支持Gemfile。因为已经有.gemspec文件,所以没有正当理由为什么要这样做。(有足够多的gem可以在没有Gemfile的情况下运行良好)事实上,itisrecommended将其用作gems的Gemfile的唯一内容:source'http

sql - ActionView::Template::Error (PG::UndefinedFunction: ERROR: operator does not exist: integer ~~ 未知

为了在Heroku中使用,我从MySQL切换到了PostgreSQL。现在我的搜索不起作用。无法弄清楚运营商出了什么问题。ActionView::Template::Error(PG::UndefinedFunction:ERROR:operatordoesnotexist:integer~~unknown.2014-11-11T19:59:58.082607+00:00app[web.1]:ProcessingbyAllListingsController#search_listingsasJS2014-11-11T19:59:58.105074+00:00app[web.1]:4:

ruby - 使用 postgresql gem 异步

我正在使用Goliath(由eventmachine提供支持)和postgresgempg,目前我以阻塞方式使用pggem:conn.exec('SELECT*FROMproducts')(例如)我想知道是否有更好的方法连接到postgres数据库? 最佳答案 pg库提供对PostgreSQL异步API的全面支持。我添加了anexample如何使用它到samples/目录:#!/usr/bin/envrubyrequire'pg'#ThisisaexampleofhowtousetheasynchronousAPItoqueryth

ruby - 使用 TCPServer 的 Ruby 中的简单 HTTP 服务器

为了一项学校作业,我尝试使用Ruby和套接字库创建一个简单的HTTP服务器。现在,我可以让它通过一个简单的问候来响应任何连接:require'socket'server=TCPServer.open2000puts"Listeningonport2000"loop{client=server.accept()resp="Hello?"headers=["HTTP/1.1200OK","Date:Tue,14Dec201010:48:45GMT","Server:Ruby","Content-Type:text/html;charset=iso-8859-1","Content-Leng

ruby - 使用 RSpec 和 VCR 测试 Web API

我正在编写一个作为gem的API包装器,我想使用RSpec测试API响应。问题是所有API请求都是使用GET发出的,并且在url中包含一个APIkey:例如游戏/元数据/{api_key}这给测试带来了问题,因为我不想将APIkey保留在git存储库历史记录中。有什么方法可以进行这些规范测试,最好是使用RSpec/VCR,而不是将APIkey存储在版本控制中?我试过使用环境变量,但VCR仍然存储整个请求,而不仅仅是响应主体。 最佳答案 VCR有一个专门针对这些情况的配置选项:VCR.configuredo|c|c.filter_se

ruby - 使用 Open::URI 显示 HTTP header ?

使用Open::URI,我可以执行以下操作:require'open-uri'#checkstatusopen('http://google.com').status#getentirehtmlopen('http://google.com').read是否可以获取请求的HTTPheader以便进行调试,例如Curls的curl-Ihttp://google.com?$curl-Igoogle.comHTTP/1.1301MovedPermanentlyLocation:http://www.google.com/Content-Type:text/html;charset=UTF-8